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NETHOO ANO APPARATUS FDR DETERMINING OESIRED RECEPTION FREQUENCY USING 
BROADCASTER INFORMATION. 

Rrlirrfl Aimiiculmw 

The subject ratter of this application is related to the subject matter of the following 
applications: application aerial number AAAA, entitled, "COMPACT GRAPHICAL 
5 INTERACTIVE INFORMATION SYSTEM*, and application serial number BBBB, entitled 
"METHOD AND APPARATUS FOR ROUTING CONFIDENTIAL INFORMATION', each of 
the above applications filed by Eric E Del Sesto and Brian P. Dougherty on April 25, 1995, 
having the same assignee as the present invention and incorporated herein by reference in their 
entirety. 

io Field of Invention 

The present invention relates to broadcast and receiving systems, and more specifically, 
to interactive broadcast and receiving systems. 

Background of Invention 
Interactive information systems allow an information provider to broadcast information 

15 to a user, and in some cases allow a user to send a response to a response collector. The user 
may receive the information on a wide variety of devices, such as a pager, cellular telephone, 
personal digital assistant or a television. An interactive information system on which the user 
receives the information using a television is called an interactive television system. 

An interactive television system can enhance the television viewing experience. An 

20 interactive television system allows an information provider to broadcast information to users for 
viewing on their television systems, and defines how a user is allowed to control the time, order 
or type of information displayed, or other aspects of the application or the user's environment 
An interactive television system may allow the user to send to a response collector responses to 
the information received, or new information. 

25 Some capabilities which could be provided using interactive information systems require 

the use of broadcaster information which can be specific to a group of users, a broadcaster or an 
information provider. Broadcaster information includes broadcast channels available to the user, 
the broadcast frequency co rre spon ding to the channel, call letters corresponding to a broadcaster 
on the channel, network identifiers for the broadcasters, or interactive information protocol or 

30 location information for a broadcast or an application. 

For example, to provide an interactive information system capability which lists a 
channel guide of available cable television channels, it is necessary to identify which channels a 
user is capable of receiving. This information varies among cable systems, making it difficult to 
provide this capability to an interactive user community which spans multiple cable systems. To 

35 provide an interactive information system capability which allows a user to change television 
channels by indicating a desired network or station call letters, it is necessary to know which 
channels are used to carry the desired station, or which channels are used to cany the desired 
network's programming. Channel information varies among cable rystems, and network 
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information varies among geographic region, making it difficult to provide this capability to an 
interactive user community which spans multiple cable systems or geographic regions. 

Some interactive information systems which utilize a variety of methods to broadcast 
interactive information may require certain information in order to operate properly. For 
5 example, one broadcaster may broadcast interactive information on a frequency unrelated to the 
broadcast program, and another broadcaster may broadcast interactive information in the same 
frequency as the broadcast program. Identification of the program broadcast frequency, 
interactive information broadcast frequency and data transport mechanism may be necessary to 
coordinate broadcast p ro gram s with the interactive applications which relate to the program. 
10 Some interactive information may be broadcast unrelated to any broadcast program, and it is 
desirable to allow the user to access this information in a manner similar to accessing broadcast 
channels. 

Knowledge of the interactive information broadcast frequency may not be ■frquatr to 
obtain the interactive information. For example, some interactive information systems use the 

IS vertical blanking interval or VBL to transport the interactive information to the user. The VBIis 
a portion of the television picture which is broadcast, but not typically seen by the television 
viewer, and readily allows for insertion of data, such as closed captioning text However, the 
various portions, or lines, of the VBI may be used for different purposes, and the use of the VBI 
may vary in various geographic regions, making a uniform placement of interactive data difficult 

20 or impossible. It may be necessary for an interactive information system which uses the VBI or 
other transport to identify the precise VBI or other transport location of the interactive 
information. 

interactive information system applications may not only relate to the content of a 
broadcast program, they may also relate to one another. To allow interactive information system 
23 applications to interact with one another, it may be necessary to identify the broadcast location of 
the interactive data for other applications. A broadcast location may include frequency and 
transport information, such as VBI line. 

Many interactive information system protocols may be used to broadcast interactive 
information. To allow an interactive information system to utilize various interactive 
30 information system protocols, it is desirable to identify which protocol is in operation on a 
particular frequency and transport mechanism. 

fkf*m*m interactive information providers may provide interactive information for use 
over a wide geogr aph ic region, it would be cumbersome to require an information provider to 
identify all of this information for each user, and provide customized interactive information 
35 based upon the information identified. 

Srnn pyy °^ i nvgn *ion 
A method and apparatus allows a user's reception component to identify broadcaster 
information. Because the reception component can identify some or all of this information, the 
interactive information provider making use of the broadcaster information may use a common 
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reference across a wide geographic region, for example "change channel to CNN", relying on the 
user's reception component to adapt the reference to the user's specific broadcaster information. 

A Bri fif Tv n ff T T riftn of ^ P f » w " lg8 
Figure 1 is an illustration of a conventional television screen displaying a conventional 
5 television program with a graphical interactive information system application displayed 
according to one embodiment of the present invention. 

Figure 2A is a block schematic diagram of a provider component apparatus according to 
one embodiment of the present invention. 

Figure 28 is a block schematic diagram of a reception component apparatus according to 
10 one embodiment of the present invention. 

Figure 2C is a block schematic diagram of a provider component apparatus according to 
an alternate embodiment of the present invention. 

Figure 2D is a block diagram of developers and information providers according to one 
embodiment of die present invention. 
1 5 Figure 3 is a block schematic diagram of user equipment according to one embodiment of 

the present invention. 

Figure 4 is a flowchart illustrating a method of one embodiment of the present invention- 
Figure 5 is a block diagram representing a format of an application header record 
according to one embodiment of the present invention. 
20 Figure 6 is a block diagram representing a format of a form definition record according to 

one embodiment of the present invention. 

Figure 7A is an illustration of a conventional television display with a form according to 
one embodiment of the present invention. 

Figure 7B is a block diagram representing a format of a form object definition record 
25 according to one embodiment of the present invention. 

Figure 8 is a block diagram representing a format of a button object definition record 
according to one embodiment of the present invention. 

Figure 9 is a block diagram representing a format of a text object definition record 
according to ooe embodiment of the present invention. 
30 Figure 10 is a block diagram representing a format of a bitmap object definition record 

according to one embodiment of the present invention. 

Figure 11 is a block diagram representing a format of a list object definition record 
according to one embodiment of the present invention* 

Figure 12 is a block diagram representing a format of a timer object definition record 
35 according to one embodiment of the present invention. 

Figure 13 is a block diagram representing a format of a picture object definition record 
according to one embodiment of the present invention. 

Figure 14A is a block diagram representing a format of a resource definition record 
according to one embodiment of the present invention. 

3 
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Figure 14B is a block diagram representing a format of a text resource according to one 
embodiment of the present invention. 

Figure- 14C is a block diagram representing a format of a bitmap resource according to 
one embodiment of the present invention. 
5 Figure 14D is a block diagram representing a format of a picture resource according to 

one embodiment of the present invention. 

Figure 14E is a block diagram representing a format of a picture resource element 
according to one embodiment of the present invention. 

Figure 14F is a block diagram representing a format of a resource list according to one 
10 embodiment of the present invention. 

Figure 14G is a block diagram representing a format of a resource list element according 
to one embodiment of the present invention. 

Figure 15 is a block diagram representing a format of an update record according to one 

embodiment of the present invention. 
1 5 Figure 16 is a block diagram representing a format of an interactive icon definition record 

according to one embodiment of the present invention. 

Figure 17A is a block diagram representing a format of a script execute record according 
to one embodiment of the present invention. 

Figure 17B is a block diagram representing a fc^Tnat of a script res«inx according to one 

20 embodiment of the present invention. 

Figure ISA is a flowchart illustrating a method of broadcasting a broadcaster information 

table according to the present invention. 

Figure 1SB is a flowchart Ulustrating a method of Receiving a broadcaster information 

table according to die present invention. 
25 Figure 18C is a flowchart illustrating a method of using a broadcaster information table 

according to the present invention. 

Figure 19 is a flowchart Ulustrating a method of drawing a form on a display according to 

the present invention. 

Figure 20 is a flowchart illustrating a method of drawing an object on a display according 
30 to the present invention. 

Figure 21 is a flowchart iUustraiing a method of drawing a resource on a display 

a cc flffrm g to the present invention. 

Figure 22 is a block diagram representing a format of a resrionse record according to one 

embodiment of the present invention. 
35 Figure 23 is a block schematic diagram illustrating a response network according to one 

embodiment of the present invention. 

Figure 24 is a flowchart Ulustrating a method of allowing a user to use an unsecure 
communication line to send confidential information to an order processor according to the 
present invention. 

4 
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rVteiled Detrriprifffl of a PrefcrrM Fmhodiment 

I, Example- 

Referring now to Figure 1, a sample graphical interactive television system application 
display is shown. A display screen 110 of a conventional television 112 displays a conventional 

5 television show which contains a politician 114 giving a speech* A graphical interactive 
information system application form 116 having a border 130 is displayed by the graphical 
interactive television system on the screen 110 of the television 112. The form 116 may contain 
text descriptions 126, 128 and pictures or icons 120, 122 corresponding to buttons 118, 124 to 
allow the user to make a selection by pressing a numeric key using a conventional television 

10 remote control device. When the user indicates a selection by pressing a remote control key 
corresponding to a button 118, 124 9 a new form may be displayed containing additional 
information relating to the indicated selection. In one embodiment, one or more selections may 
cause the graphical interactive television system to send response information to a response 
collector which may or may not be the information provider. For example, button 118 can allow 

IS the user to make a S2S campaign contribution to the candidate 114, If during the broadcast 
program a second candid*** follows the first candidate 114 t an identical form 116 may be 
displayed related to information or a response collector different from that relating to the first 
candidate 114. 

Graphical interactive information is communicated to the user by broadcasting graphical 
20 interactive information system applications. A graphical interactive information system 

application is a set of definitions, commands, scripts and data which may be used to produce a 
graphical user interface, determine how a user may control the graphical interactive information 
system application and external devices and control and define response information. Graphical 
interactive applications may be broadcast to c or respond to other information broadcast, such as 
25 in the example of Figure 1 above. When the graphical interactive application is broadcast to 
correspond to a broadcast program, it is called a program application. When the graphical 
interactive application is broadcast to co r res pond to an advertisement, it is called an 
advertisement application. A graphical interactive application may be broadcast which does not 
relate to a broadcast program or advertisement, and such an application is called a graphical 
30 virtual interactive channel. For example, with a graphical interactive television system, a 
program listing guide or weather information may be broadcast independently of the other 
broadcast programs. Because of the flexibility of the system, any form of information may be 
broadcast 

II, Hardware- 

35 Referring now to Figures 2A and 2B, two components, a provider component 206 and a 

reception component 234, are used to implement a graphical interactive information system in 
accordance with the present invention. The provider component 206 allows the generation and 
broadcast of the graphical interactive information system application, and the reception 
component 234 allows for the reception, decoding, control and display of the graphical 

5 
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interactive infonnation system application. The present invention allows the provider 
component 206 to define the display and control of a graphical interactive infonnation system 
application to be displayed on the reception component 234 without requiring the high 
bandwidth normally associated with interactive infonnation systems which display a graphical 

5 user interface. The provider component 206 compresses the graphical interactive information 
system applications by isolating only the information needed to allow the reception component 
234 to produce the graphical user interface and by encapsulating the remainder of the 
application. Because of this graphical application compression and encapsulation, high 
bandwidth is not required to broadcast the application. The graphical interactive infonnation 

10 system application is broadcast to the reception component 234. which is able to reproduce a 
complete graphical interactive information application from the small amount of infonnation it 
receives from the provider component 206 plus its own resident intelligence, 
ft pmvirterromaonenL 

The provider component 206 inserts and broadcasts graphical interactive information 
15 system applications onto a broadcast signal. In one embodiment, a conventional broadcast signal 
is provided by signal provider 208. In one embodiment, signal provider 208 is a program 
generator. In another embodiment, signal provider 208 is a video signal source from a live feed. 
In another embodiment, signal provider 208 is a video signal from a video storage device, such 
as a video tape recorder. 
20 The provider component 206 also contains a graphical interactive compact protocol 

generator and formatter 210. A graphical interactive compact protocol generator and formatter 
210 is used by an information provider to generate the interactive infonnation system 
infonnation to be broadcast In one embodiment, the graphical interactive compact protocol 
generator and formatter 210 is a conventional 486 personal computer system with a stored 
25 program for operation as described below. The graphical interactive compact protocol generator 
and formatter 210 generates the compact protocol, described below, in response to commands 
provided to it by an infonnation provider. In one embodiment, the infonnation provider types in 
the cmnpact protocol bytes which will represent the graphical user interface as described below. 
In another ernbodiment, a visual interface is used to allow a form designer to design forms and 
30 inmiealatdyseehwrJ^wUl appear. Tte gra|Mcal toteractive coir^ 

formatter 210 translates and formats the form appearing on the computer screen of the graphical 
interactive compact protocol generator and formatter 210 into the compact protocol described 
below. In another embodiment, the graphical interactive compact protocol generator and 
formatter 210 receives assignment of attribute commands such as forml .bordercolor » red, and 
35 generates the proper compact protocol cornmands as described below. 

A compact protocol inserter 212 inserts the compact protocol from the compact protocol 
generator 210 into the broadcast medium. The broadcast medium is the frequency spectrum used 
to carry the compact protocol. In one embodiment, tbe graphical interactive formation system 
is a graphical interactive television system, the broadesst medium is a standard North American 

6 
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television signal according to NTSC standards, and the vertical blanking interval or VBI, is used 
as a transport to broadcast the compact protocol. A transport is the specific portion of tbe 
broadcast medium which will cany the compact protocol. 

In one embodiment, conventional methods are employed to insert data into the VBI of a 
5 conventional broadcast from a broadcast device. Toe North American Broadcast Teletext 
Standard HA-506, OSI layers M, defines the methods and protocols for sending data in one or 
more lines of tbe VBL In one embodiment, tbe conventional TDS-3 Data Delivery System, 
available commercially from Norpak of Katana, Ontario, Canada acts as a compact protocol 
inserter 212 by receiving an RS-232 serial bit stream, buffering the bit stream, and inserting the 
10 bits over one or more lines of the VBL 

In one emhnHtment, error cheeking or error correcting corfea men ■* Hamming f r>df S tUT 

inserted with the data. In one embodiment, the compact protocol inserter 212 translates the data 
into a Hamming code, and in another embodiment, the compact protocol generator 210 produces 
Hamming coded data or adds a parity bit 

1 5 Tbe compact protocol inserter 212 is coupled to a transmitter 214 which broadcasts the 

compact protocol described below* In ooe embodiment, the transmitter 214 is a conventional 
television broadcast transmitter which receives and broadcasts the signal from conventional VBI 
inserter 212 which includes tbe conventional broadcast program and advertisement output signal 
from program generator 208, and the compact protocol from compact protocol generator and 

20 formatter 210. In this fashion, graphical interactive television information may be broadcast on 
the same frequency with a related television program. 

In another embodiment, the transmitter 214 is a conventional cable system head-end 
amplifier. In another embodiment, the signal provider 208 does not output a television program, 
and the compact protocol is broadcast without a television program. 

25 In another embodiment, the transmitter 214 is a conventional cellular telephone 

transmitter. In another embodiment, transmitter 214 is a conventional pager transmitter. These 
embodiments allow interactive information systems to be used independently of a conventional 
broadcast such as a television broadcast if desired, allowing tbe user to access the information 
from a cellular telephone or cellular equipped personal digital assistant, or even a pager. 

30 A graphical interactive television system need not use the VBI to broadcast a compact 

protocol for use with a television program, as a wide variety of other transports are available. 
Some of these transports broadcast the compact protocol separately from tbe television program, 
yet retain tbe ability to coordinate the graphical interactive information with a television 
program. In this case, transmitter 214 does not broadcast the television program, instead 

35 allowing another transmitter to broadcast the program. This allows transmitter 214 to broadcast 
the compact protocol on any type of frequency. In one embodiment, tbe transmitter 214 is a 
conventional out-of-band transmitter which transmits the compact protocol on an unused portion 
of the television frequency spectrum. In another embodiment, the transmitter 214 is a 
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conventional FM transmitter. Any form of broadcast, wire or cable transmitter may be used to 

broadcast the compact protocol. 

In one embodiment, the developer of an interactive information system application may 

be a different person or entity from the broadcaster who broadcasts the application. Referring 
5 now to Figures 2A and 2C one ernbodiment of a provider component 266 is shown. Compact 

protocol generator and formatter 276 is similar to compact protocol generator and formatter 210. 

However, the compact protocol generator and formatter 276 is not a part of the provider 

component 266. Instead, another party known as the developer develops the graphical 

interactive information system applications on the compact protocol generator and formatter 276 
10 and provides them via diskette or modem or other communication device to the information 

provider. 

The information provider loads the graphical interactive information system application 
from the developer into a graphical interactive information system application server 270. The 
graphical interactive information system application server 270 sends the graphical interactive 

15 information system application to the compact protocol inserter 272, which is similar to compact 
protocol inserter 212, and controls the operation of the compact protocol inserter 212 to allow, 
for example, the information provider to control the transport . such as VBI line used to 
broadcast the graphical interactive information system application. In another embodiment, 
graphical interactive information system application server 270 also controls the frequency of the 

20 application broadcast. Transmitter 274 is similar to transmitter 214. 

This arrangement allows for multiple parties to contribute to the graphical interactive 
information system. Referring now to Figure 2A,2B, and 2D, one embodiment of the providers 
of graphical interactive information is shown. Graphical interactive information system 
application developers 281, 282, 283, 284, 285 develop applications using compact protocol 

25 gexieraton arid fonrattm 276 for one or more 

programs, graphical interactive information system applications using provider components 266, 
or both, to users and cable operators 292, 254, who rebroadcast signab to users from 
broadcasters 286, 288, 290 and may provide additional applications or broadcaster information 

using provider co m p on ents 206 or 266. 
30 r p>^H«n fia n p^i . n».«ihirai information Svfitrm Annlir- atinn Display and 

Control . 

In one etxibodiment, the reception component 234 is contained in the user reception 
equipment similar to conventional user reception equipment. Referring now to Figure 3. one 
embodiment of the user reception equipment 308 is shown. Conventional television receiver 310 
35 such as a Sony KV32V55 is coupled to a set-top decoder 312 which is coupled via cable 322 to 
antenna 316. In one embodiment, antenna 316 is replaced by a cable 324 containing a CATV 
transmission signal. The set-top decoder 312 is similar, but not identical, to a conventional set- 
top decoder, such as the Jerrold DPV7217/V5B available commercially from General Instrument 



8 



WO 94/34467 PCT/USS*04t91 

Corporation of Hatboco, PA. The internal components of set-top decoder 312 according to the 
present invention are described below. 

Referring again to Figure 2B the reception component includes a tuner 216 to receive 
from input 219 and decode a broadcast signal containing the compact protocol. In one 

5 embodiment, tuner 216 is a conventional television broadcast tuner. In another embodiment, 
tuner 216 is a conventional CATV tuner. In another embodiment, tuner 216 is a conventional 
FM tuner. In another embodiment, tuner 216 is a conventional cellular telephone tuner. In 
another embodiment, tuner 216 is a conventional pager tuner. 

The reception component also includes a data extractor 218 coupled to the tuner 216 to 

10 extract the compact protocol from the decoded broadcast signal. In one embodiment, the data 
extractor 218 is a conventional VBI inband data extraction circuit, such as pan number 
SAA5296 available from Philips Semiconductors of San Jose, CA. In another embodiment, the 
data extractor 218 is a conventional modem. Other conventional data extraction equipment and 
techniques may also be used. In one embodiment, data extractor 218 provides a serial bhstjeam 

IS containing the extracted compact protocol onto bus 232. Bus 232 is coupled to microprocessor 
222 which stores via bus 232 the extracted compact protocol information into storage device 226 
as instructed by a program stored in storage device 224, and described below. In one 
embodiment, microprocessor 222 is a conventional 68040 microprocessor available 
co mm er c ially from Motorola, Inc., of Schaumburg, 111., although any suitable microprocessor 

20 may be used. In one embodiment storage device 226 is a conventional addressable RAM 
memory array. 

In one embodiment, the microprocessor 222 uses the error code information from the 
extracted data to check or correct errors, terminating the application if errors are detected. The 
- microprocessor 222 may decode the data from the error coded data by removing the error code 
25 prior to storage in storage device 226. 

In one embodiment, storage device 224 is a conventional addressable ROM. In another 
embodiment, storage device 224 is a conventional flash memory which is readable and writable, 
yet retains its contents when power is no longer available. Such an embodiment allows any 
software or data which is resident in the reception component to be modified or chan ged by 
30 broadcasting it using the capabilities of the present invention. For example, a new feature of the 
reception component could be implemented via broadcast, eliminating the need for the user to 
replace apart of or all of the reception component to implement the new feature. 

As described below, the mi cropro cessor 222 uses the program stored in storage device 
224 and the compact protocol information stored in storage device 226 to generate the graphical 
35 user interface display information, which is sent from the microprocessor 222 via bus 232 to a 
graphics display generator 228. In one embodiment, the graphics display generator 228 is a 
conventional VOA graphics adapter, such as model number ET4000 available from Tseng Labs 
of Newtown, PA, coupled to a conventional video genlock processor, such as model GSP500 
available from Integrated Circuit Systems of Valley Forge, PA. The graphics display generator 

9 
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228 is coupled to bos 232 to receive the graphical user interface generated by the graphical 
interactive information system* 

In one embodiment, graphics display generator 228 also receives the broadcast signal 
corresponding to a broadcast program via line 227 from tuner 216 to allow simultaneous display 
5 of the broadcast program and the graphical interactive information system application. In 

another embodiment, graphics display generator 228 receives a broadcast program signal via line 

229 from optional additional tuner 252, and line 227 is not used. This two-tuner 216, 252 
approach allows a graphical interactive information application to be displayed simultaneously 
with a broadcast program without requiring the application to be broadcast on the same 

10 frequency as the program. 

The display generator 228 is coupled to a display 230. In one embodiment, the display 

230 is an LCD display. In another embodiment, the display 230 is a conventional television 
receiver and the remaining elements 235 of the reception component as later described herein are 
contained in a set-top decoder. 

IS In one embodiment, the microprocessor 222 is also coupled to a user input decoder 244 

coupled to a user input receiver 250 to allow the user to communicate with the microprocessor 
222 m order to operate the graphical interactive information system. In one embodiment, die 
user input decoder 244 is a conventional infrared remote control decoder. The user input 
receiver is a conventional infrared receiver 250 through which the user may use a conventional 

20 handheld remote control device, such as remote control 330 of Hgure 3. Remote control keys 
pressed by the user translate to coded infrared signals that are received by infrared receiver 250, 
and are decoded by the user input decoder 244 and sent to the microprocessor 222 to allow the 
user to communicate with the interactive television system. In one embodiment, the 
microprocessor 222 responds to certain remote control keys decoded when they relate to choices 

25 displayed by the user component 234, but not to other remote control keys, to allow the operation 
of functions unrelated to the graphical interactive information system application simultaneously 
with the operation of the graphical interactive information system application using the same 
user input device. 

In another embodiment, the user input receiver 250 is a conventional personal digital 
30 assistant keypad device and the user input decoder 244 is a conventional keypad decoder. In 
another embodiment, the user input receiver 250 is a conventional cellular telephone keypad 
device and the user input decoder 244 is the keypad decoder. In another embodiment, the user 
input receiver 250 is a conventional pager switching device and the user input decoder 244 is a 
conventional switching device decoder. 
35 r P^priftn cytpnn^t - Ettgmnl Device Control. 

In one embodiment, microprocessor 222 is coupled to a conventional infrared command 
encoder 256 which accepts an infrared command input and encodes a signal for a conventional 
infrared emitter 258 to allow the interactive information system to control external devices, such 
as a VCR. 

10 
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D. Reception Component - Return Channel. 

In one embodiment, certain user responses are sent to a response collector for processing. 
Referring momentarily to Figure 1, button 118 allows a user to make a selection which will send 
a $25 campaign contribution to the candidate 114. Referring again to Figure 2B data line driver 
5 246 accepts data from mi cr op r oc es sor 222 and sends it to communications port 248 to allow the 
microprocessor to send user responses and other information described below to a response 
collector who may process the responses. In one embodiment, the data line driver 246 is a 
conventional modem and communications port 248 is a conventional telephone jack, which 
allows the reception c ompo n en t 234 to send user responses to a response collector having a 

10 receiving modem connected to a conventional telephone line. In another embodiment, the data 
line driver 246 is a conventional DTMF tone dialer. In another embodiment, the data line driver 
246 is a conventional controller for a system of addressable CATV set-top converters such as the 
ACC-4000 addressable controller available from General Instrument Corporation of Hatboro, 
PA, used to provide conventional pay-per-view services. In this embodiment, communications 

1 5 port 248 is coupled to receive the cable TV coax line 219 which is coupled to the tuner 216. 

E. Reception Component Ttaner Control. 

In one embodiment, mi cr o pr o c essor 222 is coupled to tuner 216 and optional tuner 252 to 
allow the mi cr o p rocessor 222 to communicate with and control the tuned frequency of die tuners 
216,252. This capability can provide such services as channel selection via the interactive 

20 information system. One such use of the service would be to allow a user to change channels 
from a program guide. The user's selection would automatically change the tuned frequency of 
the tuners 216, 252 to the desired channel. 

In one embodiment, tuners 216, 252 contain a broadcaster information table, described 
below, in a storage device 217, 253 of the tuner 216, 252 identifying the broadcaster 

25 corres ponding to each tunable channel. This allows the reception component to determine, for 
example, which channel number corresponds to the Cable News Network, which may be 
necessary because different cable systems carry Cable News Network on different channels. 
Storage devices 217, 253 are coupled to the microprocessor 222 to allow the microprocessor 222 
to determine which tuner channel number cor res p o nds to a particular station. 

30 In one embodiment, the storage devices 217, 253 are ROMs, installed ax the time of 

manufacture with the channel guide burned in. In another embodiment, storage devices 217, 253 
are flash mem ory to allow the channel guide to be received and extracted from a broadcast signal 
like the compact protocol as described above, to allow mi cr opro ce ssor 222 to store the 
broadcaster information table in storage devices 217, 253. In another embodiment, the 

35 broadcaster information table is broadcast as a part of the compact protocol described below, the 
broadcaster information table is stored in storage device 226, and storage devices 217, 253 are 
not used. 
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m. Compart Pmtncnl. 

The compact protocol is used to broadcast a compact set of information and commands 
from the information provider to the user in an efficient manner, allowing the use of low 
bandwidth transports such as the VBL 

5 Referring now to Figure 4, one embodiment of a method of sending and operating a 

graphical interactive information system using the compact protocol is shown. In one 
embodiment, an application header record is encoded and broadcast to initiate the process and 
describe the information which follows 410 412. The application header record and the 
information will define a graphical interactive information system application. One or more 

1 0 desired graphical descriptions such as object or resource definition records and optional scripts 
or commands, each described below, are encoded and broadcast in any order 416, 418. In one 
embodiment, the application header record is received and decoded 414 prior to the encoding of 
definitions, scripts and commands 416, although other embodiments encode, broadcast, receive 
store and decode the application header record, definitions, scripts and commands in one unit In 

15 one embodiment, no particular order of the steps described above is required as long as the 
application header definition is broadcast before the broadcast of any definition, script or 
command in the application. The information broadcast is received and de c oded and used by the 
reception component to display the graphical information and to allow the user to interact with 
the information broadcast and perform the functions described herein 420, 422. Some or all of 

20 the information broadcast may be stored at any time 420. 

In one embodiment, a graphical interactive information system application is broadcast 
again and again, allowing a user to tune to a program at any time yet receive the entire graphical 
interactive information system application. 

Any desired updates as described below may be encoded and sent 424 and received and 

25 decoded 426. If there are additional definitions or updates of resources or objects, they may be 
sent untU the application is complete 428, 430. In one embodiment, a termination command 
described below is broadcast to stop the operation of the application 430. 

As described below, a new application may be sent while an original application is in 
operation or transmission, for example, to allow a new advertisement application to interrupt an 

30 original program application, which resumes operation upon termination of the advertisement 
application In one embodiment, the new application is also broadcast and operated using the 
method described above and shown in Figure 4. A suspend application command is sent by the 
new or original application in order to suspend the operation of the existing application, and a 
resume application command may be sent by either application to terminate the new application 

35 and resume the operation of the original application. In another embodiment, the new 
application must send a termination command in order to terminate itself, as a resume 
application command would only suspend the new application and resume the original 
application. 
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Because descriptions of standard graphical objects art transmitted in place of many of the 
bitmaps or other high-bandwidth display components which would otherwise be required* 
several advantages are realized First, a low-bandwidth transport such as the VBI is aA *pmtf to 
allow the display of complex graphics. Second, the system is device-independent The 
5 information provider simply describes the effect desired and each reception component 

reproduces it as best it can. An effect or image for which display is not allowed or not possible 
on the reception component can be ignored by that reception c omp on en t, but displayed on other 
reception components. 

A A pplirairiffli Hauler Rgcirrrt 
10 In one embodiment, an application begins with an application header record to identify 

the information as the start of an interactive application. In one embodiment, if application 
information is received without an application header, the application may be stored, but may not 
run. 

Referring now to Figure 5, ooe embodiment of an application header record 508 is 
IS shown. Byte 510 identifies the data as an application header record 508, by having a value equal 
to 1. Byte 512 describes the application type. Byte 512 having a value equal to 0 signifies a 
program application such as that described above for use with the politician's speech. Byte 512 
equal to 1 signifies an advertisement application. 

Byte 512 may have a value equal to 2, signifying a virtual interactive channel. Byte 512 
20 may have other values, indicating other forms of applications. 

Referring now to Figures 2A, 2B and 5, bytes 514, 515 contain the version and revision 
number, respectively, of the protocol used to communicate between the provider component 206 
and the reception component 234 as described below. The receipt of version and revision 
numbers by a reception component 234 allows the reception component 234 to respond to 
25 protocols which are generated by different versions or revisions of the protocol generator 210. In 
one embodiment, the reception component 234 disregards a protocol which specifies a version 
number of which the reception component 234 is unaware or incompatible. 

Referring again to Figure 5, long word 516 is an application identifier, a unique identifier 
which identifies the application. This information may be sent to a response collector to identify 
30 the information provider and application which generated the response. In one embodiment, a 
long word is four bytes in length, although other lengths may also be used. 

Bytes 518, 522, and word 520 assist the mi cr op r ocessor in its memory management 
function described below by identifying many of (he memory requirements in advance. In one 
embodiment, a word is two bytes in length, although other lengths may also be used. Byte 518 
35 contains the number of forms in the application, byte 522 identifies the total number of script 
resources, and word 520 identifies the total number of text, bitmap and picture resources defined 
by the application. These terms and their operation are described below. 

In one embodiment, bytes of all records are broadcast in the order shown in the Figures 5, 
6, 7B, 8, 9, 10, 11, 12, 13, 14A, 14B, 14C, 14D 9 14E, 15, 16, 17A, 17B and 22. 
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B. GraphieaiQhjgftDgfinirions. 

The compact protocol allows the broadcast of graphical interactive information by the use 
of a set of graphical object definitions* Graphical object definitions describe characteristics of 
graphical objects, such as size of the object, color of the object, location on the display, and other 

5 characteristics of the graphical object Graphical objects include the fonn object, buttons on the 
form, bitmaps, pictures, lists, as well as non-graphical objects such as timers. In one 
embodiment, a text object contains descriptive information such as font and color about a text 
string, as well as the location of the text string, but does not contain the text string itself. Text 
strings are resources, and are separate from a text object which describes them. 

10 1 Form Definition Record. 

Each application may contain one or more forms. A form is a collection of objects which 
are defined as a single unit by the information provider using a form definition record. Objects 
in a form which are capable of being displayed are displayed together. 

Referring now to Figure 6, one embodiment of a form definition record 608 is shown. 

15 Byte 610 has a value of 2 to identify the record as the start of a form definition. Word 611 is the 
size, in bytes, of (he form definition record. Byte 612 is an identifier assigned by the information 
provider to identify the form defined by the form definition record 608. In one embodiment, a 
second form having the same form number as one already defined in an application is ignored. 
Block 614 contains one or more object definitions for the form as described below. 

20 Referring now to Figures 2B and 6, in one embodiment, after microprocessor 222 

receives a form definition record 608, the mi cr opro ces sor 222 under control of a program stored 
in storage device 224 allocates an area of the storage device 226 for the form, the objects on the 
form, resources required by the form and application control information to allow the user to 
interact with the form. Microprocessor 222 generates and stores several tables in storage device 

25 226 as described below. 

T nh^eet Definitions. 

Several standard objects may be defined using compact object definitions, which allow 
the user to specify the look of graphical objects by transmitting an object identifier as the first 
byte of the object, and only a few parameters. 
30 *- Form Objects. 

One type of object is a form object. A form object defines a rectangular region of the 
screen and the appearance of the region. The information provider defines form objects using a 
form object definition record. 

Referring now to Figure 7A, one embodiment of a form object 700 having a border 706 
35 and an interior 702 is shown displayed on a screen 703 of a conventional television set 704. 

The form object may be transparent, in which case the other objects in the form appear to 
float over the display. If the display is a television screen, and the application is not a graphical 
interactive virtual channel, a transparent form object can cause the other objects in the form to 
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appear to float over the broadcast picture. Otherwise, the form object covers all or a part of the 
broadcast picture and the objects may cover all, a part, or none of the form. 

Referring now to Figures 7A and 7B, one embodiment of a form object definition record 
70S is shown. Byte 710 identifies the object as a form by having a value of 000001 in the least 

5 significant six bits. Bytes 712, 714, 71«, 718 contain the position of the left side, top, right side 
and bottom of the form 700, respectively, relative to the center 701 of the screen 703 using a 
coarse coordinate system. A coarse coordinate system is a representation of a unit of width and 
height In one embodiment, the unit of width and height is selected to allow representation of the 
entire width or height of the display in a single byte of 256 unique numbers. In one embodiment, 

1 0 the display is a North American television signal television screen according to NTSC standards 
having a width of 160 color clock widths, each color clock width being the width covered by the 
electron beam in 280 nanoseconds, and a height of 400 interlaced scan lines. In one 
embodiment, coarse coordinate units equal one color clock in width and two scan lines in height. 
In one embodiment, the center 701 of the screen 703 is represented as coarse coordinates 128, 

IS 128. 

Byte 719 contains a description code for the style of the border 706 of form 700. In one 
embodiment, valid description codes are 0 for no border, 1 for a thin line border, 2 for a thick 
line border, 3 for a gothic style border, and 4 for a border having a "wavy" appearance, though 
other embodiments could use other codes or styles. Byte 720 contains a color code for the color 
20 of the border 706. Byte 721 contains a color code for the color of the interior 702 of the form 
700. 

Byte 722 and word 724 are used to locate the script, described below, for the form. Byte 
722 is an index into a script handle table for the location of the first byte of a script resource 
containing the script to execute. A script handle table is a table of pointers to the script resources 
25 for the application. A script resource is a block of memory which may contain numerous 
scripts. In one embodiment, a script resource may not exceed 64K bytes in size. Word 724 
contains the offset from the first memory location of die script resource to the initialization 
script 

If the most significant bit of byte 710 is set, block 730 contains optional hint information 
30 regarding the appearance of the form, such as textured appearance or transition effects such as 
fade in and fade out Hints for ooe embodiment are listed in Appendix A. If the capabilities of 
the user's interactive system cannot accommodate the appearance or effects indicated by the 
hints, the interactive system may ignore the information or display it as closely as possible. If the 
roost significant bit of byte 710 is cleared, block 730 contains no bytes and is not used. 

35 h. Button Objects- 

Another object is the button object Referring now to Figure 1, buttons 118, 124 are 
selected by the user in order to interact with the graphical interactive information system. A 
button is defined by the information provider using a button object definition record. 
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Referring now to Figure 8, one embodiment of a button object definition record 808 is 
shown. Byte 810 has a value of 2 to identify the definition is t button object Bytes 811, 812, 
813, 814 identify the positions of the left edge, top edge, right edge, and bottom edge of the 
button as a distance from me upper left hand corner of the form in coarse coordinate units. 

5 Word 816 contains a resource number corresponding to a text, bitmap ot picture resource 

to use for the button. Numbers on me button are inserted automatically on this image based 
upon the location of the button on the form. Optional byte 817 contains text color information, 
and optional word 818 contains bits corresponding to the font, size and style of the text if the 
resource is a text resource, indicated by setting the second most sigm^cantbh in Byte 817. 

10 Resources are described below, faorieerabodiment, the text size measurement is in l/500th of a 

display scre en height 

Byte 820 contains an index into the script handle table to the pointer for the script 
resource containing the script to execute when the user selects the button. Word 822 contains an 
offset from the start of the script resource to the script to be executed when the user selects the 
IS button. 

The most significant bit of byte 810 is set if hint information exists in block 828. A hint 
is a description of bow an object can appear on certain systems capable of displaying such an 
appearance. Where the reception cotnpooent is not capable of such a display, the hint may be 
ignored, or me reception component may provide an appearance matching the desired 
20 appearance as closely as possible. Numbers are assigned to buttons and displayed by the 

reception component but these assignments may be overridden using hints. Other hints for one 
embodiment are listed m A ppendix A . Optional block 828 contains one ot more bytes of the hint 
data if the most significant bit of byte 810 is set and block 828 contains no bytes otherwise. 

e. Text Objects. 
25 Text object descriptioM are provided b^ 

and appearaxice of text but do «* contain any of the actual text itself. The text itself is a 

resource, described below. 

Referring now to Figure 9, one embodiment of a text object definition record 908 is 
shown. Byte 910 contains an object type identifier having a value of 3 to indicate the object is a 

30 text object Bytes 912, 914, 916, 918 describe the left edge, top edge, right edge and bottom 
edge, respectively, in coarse coordinate umttfromtheuimerleftcomerof thefomobject of a 
box mm wruch the text resource may be placed by tte Byte 920 contains a 

code for the color of the text Byte 922 contains text alignment information. Word 924 contains 
the resource handle of the text string which the reception component is to display in the box. 

35 Word 926 defines the font size and style to use to display the resource. The font makes 

up the first four bits, the size makes up the next six bitt ai»d tne style makes up the reimuning six 
bio of word 926. 

Block 932 contains optional hint flags, size and data similar to the hints described above 
and shown in Figure 8. 
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d. Bitmap Objects. 

A bitmap object is used to display a bitmap resource, described below, on the form. An 
information provider defines a bitmap object using a bitmap object definition record. 

Referring now to Figure 10, one embodiment of a bitmap object definition record 1008 is 
5 shown. The least significant six bits of byte 1010 contain an object type identifier having a value 
of 4 to indicate the object is a bitmap object Bytes 1012, 1014, 1016, 1018 define the left edge, 
top edge, right edge and bottom edge, respectively, in coarse coordinate units from the upper left 
corner of the form object, of a box into which the bitmap may be placed. 

Word 1022 contains a handle to the resource containing the bitmap. Block 1032 provides 
10 hints as described above and shown in Figure 8. 

e. List Objects . 

A list object provides the user with a list of options and allows for a selection of one or 
more options. An information provider defines a list object using a list object definition record. 
Referring now to Figure 11, one embodiment of a list object definition record 1108 is 
15 shown. The least significant six bits of byte 1110 contain an object type identifier having a value 
of 5 to indicate the object is a list object Bytes 1111, 1112, 1113, 1114 define the left edge, top 
edge, right edge and bottom edge, respectively, in coarse coordinate units from the upper left 
comer of the form object, of a box into which the list may be displayed. 

If the second most significant bit of byte 1110 is set, then word 1116 holds font, size and 
20 style information similar to word 926 of Figure 9 and Byte 1117 holds the color code of the list, 
otherwise word 1116 and byte 1117 are unused. Byte 1118 holds the number of entries in the 
list, and byte 1120 allows a default selection to be specified using the order of the entries in 
block 1122 beginning with entry 0. In one embodiment, the default selection is initially 
highlighted to indicate which entry will be selected by the user if the user selects a button marked 
25 "yes* as instructed by the scripting commands described below. Block 1122 contains one or 
more words containing the resource handle, described below , of the each entry in the list 

Optional block 1128 provide optional hint data as described above and shown in Figure 
8. In one embodiment, the reception component displays the resources along with a number it 
flg yj g flff to each resource to accommodate selection by the user, unless overridden by hints. In 
30 another embodiment, user responses, such as specific remote control keys, are assigned to move 
a cursor up or down the items in the list 
f Timer Obtects. 

Tuner objects allow the graphical interactive information system application to use timed 
events, such as a timed response to a question in a game. An information provider defines the 
35 timer object using a timer object definition record. 

Referring now to Figure 12, one embodiment of a timer object definition record 1208 is 
shown. The least significant six bits of byte 1210 contain an object type identifier having a value 
of 6 to indicate the object is a timer object. The second most significant bit of byte 1210 is a flag 
indicating if the timer operates one time, or restarts again after each period has elap&id. Word 
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1212 contains i value equal to the period of the timer in l/60ths of a second. Byte 1214 contains 
the script handle of the script resource containing the script to execute at the end of the period 
indicated as described above. Word 1216 contains an offset from the stare of the script resource 
specified as described above to the script to execute when the period has elapsed from the time 
5 the object is received or the last period ended. 

g, Picture Objects- 

A picture object allows an information provider to define a picture using a picture 
resource, which is a list of several bitmaps, text resources and drawing primitive functions, 
which can allow the picture resource definition to be more compact than an equivalent single 
10 bitmap resource. An information provider defines a picture object using a picture object 
definition record. 

Referring now to Figure 13, one embodiment of a picture object definition record 1308 is 
shown. Byte 1310 contains an object type identifier having a value of 7 to indicate the object is a 
picture object Bytes 1312, 1314, 1316, 1318 define the left edge, top edge, right edge and 

15 bottom edge, respectively, in coarse coordinate units from the upper left corner of the form 
object, of a box into which the picture resource may be placed. 

Wend 1322 contains the handle of a picture resource, described below, to display in the 
box. Block 1328 provide hints as described above and shown in Figure 8. 
C Rctautk Definitions- 

20 Unlike object definitions which define the appearance of an object, resources represent 

data which can be displayed. The compact protocol also allows the information provider to 
define certain resources, such a bitmaps, to provide the pictures or icons 120, 122 shown in 
Figure 1. Text is also provided through the use of resources. Some resources are predefined, 
and others may be defined by the information provider. An information provider defines 

23 resources using resources definition records. 

Referring now to Figure 14A, one embodiment of a resource definition record 1408 is 
shown. Byte 1410 identifies the record as a resource definition record by having a value equal to 
2. Word 1411 contains a value equal to the number of bytes in the resource definition record. 
Word 1412 is the resource handle of the resource. 

30 In one embodiment, four types of resources may be defined in block 1414, a text 

resource, a bitmap resource, a picture resource and a bitmap resource list The stored program in 
the storage device erf the reception component will interpret the resource and format it according 
to the capabilities of the reception component so that it may be rendered as closely as possible to 
the definition. If necessary, the stored program may discard a resource definition data that it 

35 cannot use, for example, because the resource has a higher resolution than the reception 
component is capable of rendering as described below. 
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1 Text Resource 

A text resource conuins text data. Referring sow to Figure 14B, one embodiment of a 
text resource 1428 is shown. Byte 1430 having a value equal to 1 identifies the resource as type 
text, and block 1432 contains a null terminated text string, such as ASCHZ. 

S Bitmap Resource 

A bitmap resource is used to hold bitmaps. Bitmaps are described in Kliewer, EGA/VGA 
Programmer's Reference Guide (2nd. ed, McGraw Hill 1990). Referring now to Figure 14C, 
one embodiment of a bitmap resource 1438 is shown. Byte 1440 having a value equal to 2 
identifies the resource as type bitmap. In one embodiment, the resolution of the bitmap is higher 

1 0 than the coarse coordinate system, allowing the utilization of the full display resolution of the 
reception component Bytes 1441* 1442, 1443, 1444 define four colors for use as described 
below. Word 1446 defines the width in pixels of the bitmap and word 1448 defines the height of 
the bitmap in pixels. Block 1450 contains one or more bytes of the bitmap data, each byte in 
block 1450 containing four pairs of bits, each pair representing one of the four colors defined 

15 above, of a pixel. pixel is drawn to the right of the pixel before until the pixel width 1446 
is reached, at which point the next pixel is drawn at the left boundary of the next row and the 
process repeats until all the pixels are drawn. 

Any form of bitmap or similar format may be used. For example, bitmaps using a byte 
per pixel, where each byte represents the color of a pixel, may be used. 

20 In one embodiment, the bitmap data is compressed using such compression techniques as 

conventional run-length encoding. 
3. Picture Resources. 

Picture resources are used to hold zero or more graphical elements such as text strings, 
- bitmaps, and primitive drawing functions, as well as relative position information. Referring 

25 now to Figure 14D, ooe embodiment of a picture resource 1458 is shown. Byte 1460 having a 
value equal to 32 identifies the resource as type picture. Word 1462 contains the number of 
bytes in the picture resource definition record. Block 1464 contains zero or more picture 
resource elements described below. 

Referring now to Figure 14E, one embodiment of a picture resource element is shown. 

30 The least significant six bits in byte 1470 indicate the type of the element. Element types include 
text or bitmap resou«^es, as well as drawing functions such as ellipse, circle, horizontal line or 
vertical line. The type co^es are listed for one embodiment are: text = 24, bitmap « 32, point 
drawing function « 1, horizontal line drawing function « 2, vertical line drawing functions 3, 
rectangle drawing function * 4, filled rectangle drawing function = 5, diagonal line drawing 

35 function ■ 6, ellipse drawing function » 7, circle drawing function = 8, and spline drawing 
function ■ 9. The most significant bit of byte 1470 indicates t£ic last element in the picture 
resource, allowing multiple elements to be a part of a picture resource. Bytes 1472, 1474 contain 
the x and y coarse coordinate relative so the center of the screen of the upper left comer of the 
element, and bytes 1476, 1478 contain the x and y coarrc coordinates relative to the center of the 
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screen of the lower right comer of the element, except for the horizontal line drawing function, 
which does not contain byte 1478, the vertical line drawing function, which does not contain byte 
1476, and the point drawing function and bitmaps which do not contain bytes 1476 or 1478 
because in each case, the omitted byte or bytes are unn ece ssa r y. Byte 1480 contains the color 
5 code for the element, unless the element type is bitmap. Word 1482 contains a resource handle if 
the type is text or bitmap, otherwise, word 1482 is unused. Block 1484 contains additional 
information if the type is text, similar to word 926 of Figure 9. 
4- Resource Lists 

Resource lists contain one or more bitmap resources. Referring now to Figure 14F, one 
10 embodiment of a resource list 1488 is shown. Byte 1490 contains a unique value to identify the 
resource as type resource list Block 1492 contains one or more resource list elements. 
Referring now to Figure 14G, one embodiment of a resource list element 1498 is shown. Word 
1497 contains an offset to the byte following die resource list element, or zero if resource list 
element 1498 is the last element in the list Block 1499 contains a bitmap resource described 
IS above and shown in Figure 14G 
P TnriMitiy Definitions. 

Referring now to Figure 2B, in one embodiment, microprocessor 222 performs several 
memory management functions. Microprocessor 222 maintains in storage device 226 a pointer 
to each form in an application using a form handle table. The form handle table contains a 

20 pointer to the first byte of each form object in the application. The objects in each form are 
stored as a linked list, with the form object pointing to the first object in the linked list An 
object is located by using the form handle table to locate the form, and then traversing the linked 
list until the desired object is located. In one embodiment, objects may be referenced by type and 
position in the list For example, button 3 is the third button found while traversing the list In 

25 another embodiment, all objects are sequentially numbered in the list, and objects are referred to 
by this object number. 

The location of each resource is stored using a resource handle table in which each entry 
in the table contains a pointer to the resource. The resource is located by using a resource handle 
index to locate the pointer in the resource handle table, and using the pointer to locate the 

30 resource. 

flr^f* several applications may be resident in the storage device 226 at one time, more 
than one set of the tables and lists described above may be maintained by microprocessor 222, 
allowing a program application to stay resident while an advertisement application is operating, 
so that the program application need not be reloaded after the end of the advertisement when the 
35 program resumes. The program application or advertisement application may be suspended or 
terminated by an ufcertiseroent spplicction. In one embodiment more than one advertisement 
application may be resident in storage device 226 to allow a user to send a response to one 
advertisement application after tfce advertisement terminates, yet still receive the application for 
the following advertisement In one embodiment only the form or forms of the application 
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related to the response will remain in storage device 226 after microprocessor 222 receives a 

second advertisement application. 

In one embodiment, a program application is allocated a larger percentage of memory 

than an advertisement application due to the longer running time of the program application. In 
5 one embodiment, a program application may occupy 75% of the available memory as described 

below, leaving 25% for one or more advertisement applications. A virtual interactive channel 

application may occupy 100% of the available application memory. 

In one embodiment, memory is allocated by limiting the number of available handles in 

the application's handle table based upon the type of application as described above. Although 
10 this embodiment does not strictly enforce the actual memory usage of the application, it provides 

a reasonable level of protection without a significant increase in complexity of memory 

management In this embodiment, the number of handles to be allocated may be based upon 

experience of the average size of the memory required as a result of each entry in the handle 

table. In one embodiment, the average size per entry is 50 bytes. 
1 5 in another embodiment, memory itself is allocated by tracking the amount of memory a 

graphical interactive information system application uses as the memory is reserved, and 

terminating the application if the application's memory allocation is ex c eeded. 
R Updates. 

The compact protocol also allows the information provider to update information used by 
20 previous definitions so that the appearance of a form can be modified quickly without resending 
a large amount of data required to resend the entire application or form. An information provider 
sends an update record to replace a form, one or more objects on a form, or one or more resource 
definitions in an application. 

Referring now to Figure 15, one embodiment of an update record 1508 is shown. Byte 
25 1510 having unique values to identify the record as an update record to update a form, one or 
more objects on a form, or one or more resources, respectively. Word 1512 identifies the size in 
bytes of the record Block 1514 is the handle of a form to replace, the form containing the 
objects to replace or the resource to replace. Block 1516 contains a form object definition 
record, one or more button, text, bitmap, picture, timer or list object definition records, or text or 
30 bitmap resource definition records described above to replace the object or resource indicated in 
byte 1514. 

hi one embodiment, entire forms are updated by storing the objects of the form and 
adjusting the handle to the old form to point to the new form. One or more objects in a form 
may be updated by storing die new object and then inserting the new object in the linked list 
35 making up the form in place of the old object A resource is updated by storing the new resource 
and adjusting the resource handle table to p;;*nt to the new resource. 

F Instructions. 

The compact protocol also allows the information provider to send instructions to the 
reception component to control the operation c? the interactive information system. 
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A form may be displayed using a two byte command. The first byte has a value equal to 
5 to indicate the command is a form display command, and the second byte contains the form 
number. The- form display command allows the information provider to display a form without 
any input from die user. 

5 A program application may be suspended or resumed by an advertisement application or 

virtual channel using the single byte commands suspend and resume, having a value of 6 and 7, 
respectively. An application may be permanently tenninated by sending a single byte command 
having a value equal to 8. 

(V Inflictive Ifflp rvfinttion. 
10 In one embodiment, an interactive icon is shown on the display to indicate an interactive 

application has been received by the reception component. The user can then press one or more 
keys on the remote control to display the first form of the application. The information provider 
may control the icon displayed by sending an interactive icon definition record. 

Referring now to Figure 16, one embodiment of an interactive icon definition record 
15 1608 is shown. Byte 1610 contains a value of 9 to identify the record is an interactive icon 
definition record. Bytes 1612, 1614, 1616, 1618 define the distance in coarse coordinate units, 
from the center of the screen of the left edge, top edge, right edge and bottom edge, respectively, 
of a box in which the interactive icon will be displayed. The upper left edge of the icon is placed 
at the upper left edge of the box defined. Word 1620 is the resource handle of the resource to be 
20 displayed as the icon. 
H SfiriPtt- 

Scripts are a sequence of one or more scripting cornmands provided by in information 
provider. A script may be executed when received, or may be executed in response to an action. 
In one embodiment, the cornpact protocol allows an information provider to send a script 
25 which is executed upon receipt and then <liscarded. An infonnation provider defi^ 

execute using a script execute record. Referring now to Figure 17A, one embodiment of a script 
execute record 1708 is shown. Byte 1710 having a unique value to identify the record as a script 
execute record. Word 1712 contains the number of bytes in the script execute record. Block 
1714 contains the script resource, containing one or more codes as described in Appendix, B - 
30 The compact protocol also allows the information provider to provide scripts defining the 

operation of the system in response to user selections or other events. Four objects may have 
scripts associated whh them: forms, lists,' buttons, and timers. The form object script is executed 
when the form is displayed. A list object script is executed when the user indicates a selection. 
A button object script is executed when the user selects the button. A timer object script is 
35 executed at the end of the timer period. 

A script can display or hide a form or an object on the form, modify an object's 
characteristics, such as color or size, or modify which resource an object will use. A script can 
also declare variables unique to the script and change the values of those variables. A script can 
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use standard logic functions, such as "or", "and", "if..then", etc In ooc embodiment, the script 
can perform all the math and logic functions of a conventional basic int er p re ter. 

Referring now to Figure 17B, one embodiment of a script resource 1718 is shown. Byte 
1720 having a unique value to identify the resource as a script resource. Word 1722 contains the 
5 number of bytes in the script resource. Byte 1723 contains the handle used as an identifier of the 
script resource. Block 1724 contains the script resource, containing ooe or more codes as 

described in ABDSOdilA- 

Responses are scripted as well including the formatting of a response byte or byte 

containing product information, quantity, or the like. In one embodiment, a script may contain 
10 one or more of four unique scripting commands which generate responses. 

An "order" scripting command allows a user to use the interactive information system to 

order a product or service from a vendor. An order scripting command contains a one-byte code 

representing the command, one word of cost information and a one byte variable indicator to 

allow the information provider to indicate a variable to return as described below. The cost 
1 5 information may be used by the reception component 234 of Figure 2B to check the price of the 

order to verify that it does not exceed a user's predefined limit to assist the user for budgeting 

purposes. The variable indicator is a code to indicate a variable to return as described below. 

The variable may be built by the information provider using the scripting language, and in one 

embodiment, the variable is four bytes in length. 
20 A "request* scripting command allows a user to request information for no charge. A 

request scripting command is similar to the order scripting command, but, no cost information 

byte is passed to the reception co mponen t for verification. 

Two scripting commands are used which generate anonymous responses described 

below. A "respond" command has a format similar to the request scripting command, to allow 
25 the generation of a four byte response to be defined by the information provider using the 

scripting language. A "vote" scripting command is a single byte command which generates a 

response having only one byte which contain predefined codes for "yes", "no", "abstain" and 

"dont know," to allow for simple, compact response generation. 

Referring now to Ft gure 2A, scripts are defined by the information provider usin g the 
30 compact protocol generator 210. In one embodiment, the compact protocol generator 210 has a 

user interface allowing characteristics of objects to be defined or modified or other actions to be 

taken using an object oriented format, such as "form 1 .show" to display the first form. Other 

commands such as assignment of variables and logic functions are defined using a set of 

commands similar to the BASIC programming language. 
35 The protocol generator converts the B ASIC-like commands to one or mote numeric 

codes, and includes the codes in the application broadcast One embodiment uses the codes 

described in Appendix B. 

In one embodiment, scripts are stored in a script resource, which is an area of memory up 

to 64K bytes long which stores one or more scripts. A script handle table keeps track of all script 
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resources by storing the memory location of the first byte of each script resource. The precise 
location of the start of each script is provided to the system as an index into the script handle 
table, and an offset from the location pointed to by the script handle table entry corresponding to 
the index. 

5 Scripts ait executed using a command int er p rete r which performs the functions indicated 

until it reaches an end of script identifier. In one embodiment, the script instructions are 
interpreted directly from the codes which make up the script resource, and in another 
embodiment, script instructions are first converted into C++ code prior to interpreting them. 

1 0 Referring now to Figures 2A,2B,2Cand 18C in one embodiment, an information 

provider such as a cable television operator uses the provider component 266 to create, insert and 
broadcast broadcaster information as a graphical interactive information system application for 
reception and decoding by a reception component 234. 

In one embodiment, the information provider provides broadcaster information to allow a 

IS reception component 234 to build a broadcaster information table. A broadcaster information 
table organizes some or all broadcaster information to allow the reception component 234 to 
locate the tuned frequency or other identifier of a broadcaster or an application. 

Broadcaster information may reach the information provider in a variety of ways. 
Broadcasters or other information providers may send broadcaster information relating to their 

20 broadcasts to the information provider. For example, the transport a broadcaster uses to 
broadcast graphical interactive information system applications, such as VBI line 14, and the 
broadcaster's network identifier, such as CNN, may be provided by the broadcaster to the 
information provider who will provide broadcaster information. The broadcaster can also 
identify whether it provides programs, interactivity or both, and any interactive information 

25 system protocols it uses. Thus, a broadcaster may be an information provider for interactive 
information system applications it broadcasts, and provide content to another information 
provider, the cable operator, who broadcasts the broadcaster information via its own provider 
component 206. 

The information provider who will broadcast the broadcaster information can assemble 
30 information received by others, provide its own broadcaster information or both. For example, 
the cable operator can provide the channel guide containing a frequency identifier such as the 
frequency or channel number and call letters for each of the broadcasters on the cable system in 
addition to information it receives from broadcasters or other parties. 

In one embodiment, an information provider broadcasts a broadcaster information table 
35 by broadcasting broadcaster information such as broadcast channels available to the user, the 
broadcast frequency corresponding to the channel, call letters corresponding to a broadcaster on 
the channel, network identifiers for the broadcasters, or interactive information protocol or 
location information for a broadcast or an application 1810. whether a broadcaster broadcasts 
programs, graphical interactive information system applications or both 1811, a broadcast 
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prognm toned frequency location identifier 1812, and interactive information system application 
tuned frequency identifiers 1814 for the broadcaster or for particular applications broadcast by 
the broadcaster or others. 

Referring now to Figures 2B and 18B, in one embodiment, the reception component 
5 receives the broadcaster identifiers 1820, whether a broadcaster broadcasts programs, graphical 
interactive information system applications or both 1821, broadcast program tuned frequency 
location identifiers 1822, and interactive information system application tuned frequency 
identifiers 1824 and stores this information in storage device 226. 

Referring now to Figures 2B and 18C, a desired frequency is located given any of the 

10 entries in the broadcaster information table by locating a desired entry 1830, identifying the 
tuned frequency of the desired broadcaster or interactive information system application 1832 
and tuning the desired frequency 1834. for example, if channel 4 contains KRON, the NBC 
affiliate, broadcasting graphical interactive information system applications on line 14 of the VBI 
on channel 9, this information is stored in the reception component 234 as described above. An 

1 5 interactive application corresponding to channel 7 may instruct the reception component 234 to 
switch the tuned frequency of the program channel to the NBC affiliate using a command which 
only identifies NBC as the target channel. The interactive information system reception 
c omp onent 234 may then identify the proper channel corresponding to the NBC affiliate as 
channel 4 by locating the desired broadcaster in the broadcaster information table, identifying the 

20 tuned frequency or channel of the desired broadcaster from the entry containing the broadcaster 
information 1832 and switch the tuned frequency of a tuner in reception component to the 
channel or frequency of the desired broadcaster or application 1834, When tuner 216 is changed 
to channel 4, either by the user or an interactive information system application, reception 
co mpon ent 234 under control of mi cr opro ces sor 222 using the broadcaster information table can 

25 switch tuner 252 to channel 9 and decode the line 14 of the VBI to obtain interactive information 
system applications corresponding to the broadcast program on channel 4. In one embodiment, 
the previous channel or application information is stored in storage device 226 to allow the 
interactive information system to return the user to the original channel 7, for example if the user 
exits the new application or the interactive information system application on line 1 4 of the VBI 

30 of channel 9 is not received 

Referring now to Figure 2B f as described above, in one embodiment, information related 
to interactive information system applications may also be broadcast, received and stored as a 
part of the broadcaster information table. If graphical interactive information system application 
number 5407138 will be broadcast by KRON, this information may also be a part of the 

35 broadcaster information table, allowing the interactive informal on system to locate this 
application upon command, for example, from another interactive information system 
application, without changing the program channel, for example by changing the tuned frequency 
of tuner 217 without changing the tuned frequency of tuner ?52. 
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In one embodiment, the developer uses the compact protocol generator and formatter 276 
to create interactive information system applications which refer to other applications by using 
application identifiers, and the graphical interactive information system application server 270 
allows the broadcaster to further modify the application by adding available broadcaster 
5 information regarding the other applications to allow the reception component to locate the other 
applications. 

V IfMfe Generation. 

An application may display the first form when the reception component receives the 
application header record, the first form definition, including objects for that form, and resources 

10 related to the objects on the form. Additional forms may be broadcast while the first form is 
being displayed In one embodiment, if the user response causes the application to display a 
form for which the form definition or one of the required object or resource definitions has not 
been received by the reception component, the application will wait for 10 seconds for die 
receipt of the missing information, and if not received, abort the application and display an error 

IS message* 

Referring now to Figure 2B, display generator 228 contains an addressable video RAM- 
When a VGA color code is written into the video RAM of the display generator 228, a pixel 
appears on the display 230 c o rres ponding to the address of the code written. Thus by sending 
various bitmaps, the form is displayed The use of bitmaps and video display adapters is 

20 described in Kliewer, EGA/VGA Programmer's Reference Guide (2nd ed, McGraw Hill 1 990). 

In one embodiment, all color codes are broadcast as VGA color codes. VGA color codes 
are described in Kliewer, EGA/VGA Programmer's Reference Guide (2nd ed, McGraw Hill 
1990). In another embodiment, a different set of color codes are used In one embodiment, the 
color code is converted at display time to a color suitable for the reception component by 

25 mapping it to another color. For example, some of the VGA color codes are too bright for use on 
certain displays, such as color televisions, and thus, a 236 entry lookup table is used to convert 
the VGA code into the acceptable code. In one embodiment, the result of the lookup reduces the 
saturation of the RGB values by 25%. In another embodiment, codes indicating saturation of the 
RGB values in the top 25%' are held to 75% of the maximum. The 25% value was selected to 

30 accommodate the color restrictions imposed by the NTSC video signal standards, and 

conventional color television circuitry. The lookup table approach can map to any number of 
colon. In one embodiment, 100 colors are used another embodiment uses sixteen colors, and 
another embodiment uses only two colors. 

The reception co m ponent stores bitmap resources defined using bitmap resource 

35 definitions described above in storage device 226. In one embodiment, all text characters in 
various fonts, styles and type sizes are stored as predefined bitmaps in storage device 224 to 
allow for rapid display of these character?. In another embodiment, these text characters are 
stored as outline fonts, and bitmaps are generated from the outline fonts. Other predefined 
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resources are also stored to allow commonly-used objects such as bitmaps of credit cards. 
Predefined resources are listed in Appendix C. 

Referring now to Figure 19, a method of generating the images from the form object and 
other object definitions is shown. When a display form command is received, either via the 
5 broadcast or via a script, the video RAM is erased 1910 and the objects and resources are drawn. 
In one embodiment, the form object is drawn first 1912, followed by the objects and resources 
appearing on the form 1914, 1916 until all objects and resources are drawn 1920. This allows 
the objects and resources to appear overlaid onto the form. Objects and resources are located 
using the handle tables described above. 

1 0 Referring now to Figure 20, one embodiment of a method of drawing an object is shown. 

An object is drawn by reading the corresponding object definition 2010, generating a bitmap 
c or re spon ding to the object definition read 2012 and sending it to the graphics display generator 
2014. In one embodiment, the entire bitmap is generated 2012 prior to sending 2014. In another 
embodiment, portions of the bitmap are generated 2012 and sent 2014 until the entire bitmap is 

IS complete 2016, 2018. Generating the bitmap is accomplished by rendering the color of each 
pixel within the boundary of the object as specified by the object definition. 

Referring now to Figure 21, ooe embodiment of a method of drawing a resource is 
shown. Each bit in the bitmap of a resource is read 2108 and translated 2110 into the format of 
the graphics display generator if required. For example, each bit in a four-color bitmap resource 

20 may be translated into a modified VGA color code as described above. The translated bit is sent 
2112 to the graphics display generator using the position information in the resource definition 
for display by the display device. In one embodiment, all of the bits are assembled 2110 into a 
bitmap prior to sending 2112, and in another embodiment, each bit is sent after translation 2112. 
The method continues until the resource is drawn 2114, 2116. 

25 VL Response Generation 

When an application allows a response and the user has a reception component capable 
of transmitting the response, the user may provide response information to a response collector. 
Referring now to Figure 28, in one embodiment, each reception component 234 is assigned a 
unique code at the time of manufacture and this code is stored in the storage device 224. 

30 Individual users of the reception component 234 may also be assigned a unique code. When the 
user respoods to an object which generates a response, the reception component generates a 
response record to allow the response collector to route the response as described below. 

Referring now to Figure 22, one embodiment of a response record 2208 is shown. Long 
word 2210 contains the unique code of the reception component, and long word 2212 contains 

35 the unique application code sent in the application header. Byte 2214 contains a user identifier, 
to allow the user to distinguish himself from others who may use the reception component. In 
one embodiment, anonymous responses do not contain the reception component or user identifier 
2210, 2214 to allow for the user to maintain anonymity. Block 2216 contains the defined 
response information byte or bytes described above to designate quantity or product information 
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according to me user's response. In one embodiment, a passcode is maintained in the reception 
component, and the user is required to enter it to generate the response to the response collector. 

Referring now to Figure 23, a response network containing three reception components, 
one response collector, and two vendors is shown. User reception components 2310, 2312, 2314 

5 are coupled to response collector forwarding equipment 2316 via communication lines 2311. 
Communication lines 2311 may be permanently connected or temporarily arranged as needed In 
one embodiment, communications lines 2311 are arranged through the public switched telephone 
network when a reception component 2310, 2312, 2314 dials a telephone number of the response 
collector. In another embodiment, communications lines 2311 are cable television cables. Any 

10 form of communication, even using an intermediary such as telephone equipment owned by the 
telephone company, will allow operation of the present invention. In one embodiment, response 
collector forwarding equipment 2316 is an industry standard UNIX-based computer system 
coupled to at least one modem to receive and/or transmit data. 

The response collector forwarding equipment 2316 is coupled to vendor ordering 

IS equipment 2318, 2320 using communication lines 2319 similar to communication lines 2311 to 
allow the response collector equipment 2316 to react to the receipt of responses sent by a 
reception component 2310, 2312, 2314 by sending user information and other information to 
vendor ordering equipment 2318, 2320 as described below. 

Referring now to Figure 24 a method of collecting and sending confidential user 

20 information such as credit card number to a vendor is shown. The response collector obtains 
user information such as reception component number, user number, name and address, and 
confidential information such as credit card number 2408, 2410. In one embodiment, this is 
accomplished by mail. In another embodiment, this step is accomplished by telephone. In one 
embodiment, the information is verified, for example by checking the credit card billing address 

25 with the address provided by the user 2411. 

The response collector obtains routing information and an application identifier from the 
information provider 2412, and associates the routing information with the application identifier. 

The application identifier broadcast to the user as described above and a user reception 
com pon en t and user identifiers are sent to the response collector 2414. Because no confidential 

30 information is sent, unsecure communication lines may be used to send the information. The 
response collector then forwards the user information including user confidential information 
and response information to the vendor associated with the application identifier received 2416. 
This step may be accomplished using a secure facility, such as mail or telephone line. The 
vendor may then provide a service or products to the users address with less likelihood of fraud. 
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What is claimed is: 

1. A system for allowing an interactive information system to determine broadcaster 
information comprising: 

a provider component for broadcasting broadcaster information; and 
5 a reception component comprising: 

a first tuner for receiving broadcaster information from a provider component; 
a mi crop ro c essor for comparing the broadcaster information received to a 
description, identifying a desired frequency cor resp o nding to the description, and sending 
a command to a second tuner to tune the desired frequency; and 
10 a second tuner for tuning the desired frequency. 

2* The system of claim 2 wherein the second tuner is the first tuner. 

3. A method of communicating interactive information system broadcast information 
comprising: 

broadcasting a fust frequency identifier, and 
15 broadcasting an identifier for the location of an interactive information system 

application. 

4. The method of claim 3 comprising the additional step of broadcast 
frequency identifier. 

5. The method of claim 3 comprising the additional steps of broadcasting a broadcast 
20 station identifier. 

6. The method of claim 3 comprising the additional step of broadcasting a broadcast 
network identifier. 

7. A method of receiving interactive information comprising: 
receiving via a broadcast a first frequency identifier, and 

25 receiving via a broadcast an identifier for the location of interactive information. 

8. The method of claim 7 comprising the additional step of tuning a tuner to receive the 
interactive information responsive to the identifier of location information for the interactive 
information* 

9. The method of claim 7 comprising the additional step of extracting data from a 
30 broadcast frequency responsive to the identifier of location information for the interactive 

information* 
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